#include <bits/stdc++.h>
using namespace std;
#include <atcoder/dsu>
using namespace atcoder;
using ll = long long;
using pii = pair<int, int>;
#define rep(i, a, b) for (int i = (a); i <= (b); i++)
#define per(i, a, b) for (int i = (a); i >= (b); i--)
#define endl '\n'
const int N = 2e5 + 5;

int n, m;
int a[N];

int main() {
  ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
  cin >> n >> m;
  dsu d(n);
  rep(i, 1, m) {
    int op, u, v;
    cin >> op >> u >> v;
    if (!op)
      d.merge(u, v);
    else
      cout << d.same(u, v) << endl;
  }
  return 0;
}